ActiveRecord and transactionsin between `before_save` and `save`
Posted
by JP
on Stack Overflow
See other posts from Stack Overflow
or by JP
Published on 2010-04-16T09:41:16Z
Indexed on
2010/04/16
9:43 UTC
Read the original article
Hit count: 157
I have some logic in before_save
whereby (only) when some conditions are met I let the new row be created with special_number
equal to the maximum special_number in the database + 1. (If the conditions aren't met then I do something different, so I can't use auto-increments)
My worry is that two threads acting on this database at once might pick the same special_number
if the second is executed while the first is saving. Is there way to lock the database between before_save
and finishing the save, but only in some cases? I know all saves are sent in transactions, will this do the job for me?
def before_save
if things_are_just_right
# -- Issue some kind of lock?
# -- self.lock? I have no idea
# Pick new special_number
new_special = self.class.maximum('special_number') + 1
write_attribute('special_number',new_special)
else
# No need to lock in this case
write_attribute('special_number',some_other_number)
end
end
© Stack Overflow or respective owner